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“T like my code to be elegant and efficient. The logic 
should be straightforward to make it hard for bugs to hide, 
the dependencies minimal to ease maintenance, error handling 
complete according to an articulated strategy, and performance 
close to optimal so as not to tempt people to make the code messy 
with unprincipled optimization. Clean code does one thing well.” 


— Bjarne Stroustrup 


1.1 INTRODUCTION 


Sometimes while executing a Python program, the 
program does not execute at all or the program 
executes but generates unexpected output or 
behaves abnormally. These occur when there are 
syntax errors, runtime errors or logical errors in 
the code. In Python, exceptions are errors that 
get triggered automatically. However, exceptions 
can be forcefully triggered and handled through 
program code. In this chapter, we will learn about 
exception handling in Python programs. 


1.2 SYNTAX ERRORS 


Syntax errors are detected when we have not 
followed the rules of the particular programming 
language while writing a program. These errors are 
also known as parsing errors. On encountering a 
syntax error, the interpreter does not execute the 
program unless we rectify the errors, save and 
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rerun the program. When a syntax error is encountered 
while working in shell mode, Python displays the name 
of the error and a small description about the error as 
shown in Figure 1.1. 


[a Python 17.0 She 


File Edt Shell Debug Options Window Help | 
Python 3.7.0 (v3.7.0:1b£9cc5093, Jun 27 2018, 04:59:51) [MSC v.1914 64 bit (AMD6 ~ 
4)] on win32 
Type "copyright", "credits" or "license()" for more information. 
>>> marks=10 
>>> if marks>20: 

print "GOOD SCORES 


SyntaxError: Missing parentheses in call to 'print'. Did you mean print ("GOOD 5C 
)ORE") ? 
>>> | 





Figure 1.1: A syntax error displayed in Python shell mode 


So, a syntax error is reported by the Python 
interpreter giving a brief explanation about the error 
and a suggestion to rectify it. 


Similarly, when a syntax error is encountered while 
running a program in script mode as shown in Figure 
1.2, a dialog box specifying the name of the error (Figure 
1.3) and a small description about the error is displayed. 


File Edit Format Run Options Window Help 
déf test(): 
marks=7270 


if marks>10: 
print "GOOD SCORE" 





Figure 1.2: An error in the script 














Missing parentheses in call to ‘print’, Did you mean print(Good 
e Score’)? 


























Figure 1.3: Error dialog box 
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1.3 EXCEPTIONS 


Even if a statement or expression is syntactically 
correct, there might arise an error during its execution. 
For example, trying to open a file that does not exist, 
division by zero and so on. Such types of errors might 
disrupt the normal execution of the program and are 
called exceptions. 


An exception is a Python object that represents an 
error. When an error occurs during the execution of a 
program, an exception is said to have been raised. Such 
an exception needs to be handled by the programmer 
so that the program does not terminate abnormally. 
Therefore, while designing a program, a programmer 
may anticipate such erroneous situations that may arise 
during its execution and can address them by including 
appropriate code to handle that exception. 


It is to be noted that SyntaxError shown at Figures 
1.1 and 1.3 is also an exception. But, all other exceptions 
are generated when a program is syntactically correct. 


1.4 BUILT-IN EXCEPTIONS 


Commonly occurring exceptions are usually defined 
in the compiler/interpreter. These are called built-in 
exceptions. 


Python’s standard library is an extensive collection 
of built-in exceptions that deals with the commonly 
occurring errors (exceptions) by providing the 
standardized solutions for such errors. On the occurrence 
of any built-in exception, the appropriate exception 
handler code is executed which displays the reason 
along with the raised exception name. The programmer 
then has to take appropriate action to handle it. Some 
of the commonly occurring built-in exceptions that can 
be raised in Python are explained in Table 1.1. 


Table 1.1 Built-in exceptions in Python 


al e a o 
Explanation 
in Exception 





SyntaxError It is raised when there is an error in the syntax of the Python code. 
PA ValueError It is raised when a built-in method or operation receives an argument 
that has the right data type but mismatched or inappropriate values. 
3. IOError It is raised when the file specified in a program statement cannot be 
opened. 
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4 KeyboardInterrupt It is raised when the user accidentally hits the Delete or Esc key 
while executing a program due to which the normal flow of the 
program is interrupted. 


5 ImportError It is raised when the requested module definition is not found. 

6 EOFError It is raised when the end of file condition is reached without reading 
any data by input(). 

T ZeroDivisionError It is raised when the denominator in a division operation is zero. 

IndexError It is raised when the index or subscript in a sequence is out of range. 

9 NameError It is raised when a local or global variable name is not defined. 

10 IndentationError It is raised due to incorrect indentation in the program code. 

11 TypeError It is raised when an operator is supplied with a value of incorrect 
data type. 

12 OverFlowError It is raised when the result of a calculation exceeds the maximum 


limit for numeric data type. 


Figure 1.4 shows the built-in exceptions viz, 
ZeroDivisionError, NameEError, and TypeError raised 
by the Python interpreter in different situations. 


LE eoa 
Für Edt Shell Debay Opiom Widow Help - 
Python 3.7.0 (v3.7.0:1bf9cc5093, Jun 27 2018, 04:59:51) [MSC v.1914 64 bit (AMD64)] on win32 
Type "copyright", "credits" or "license()" for more information. 
(>>> print (50/0) 
Traceback (most recent call last): 
File "<pyshell#0>", line 1, in <module> 
print (50/0) 
ZeroDivisionError: division by zero 
>>> print (vart+40) 
Traceback (most recent call last): 
File "<pyshell#1>", line 1, in <module> 
print (var+40) 
NameError: name ‘var' is not defined 
>>> 104+'5' 
Traceback (most recent call last): 
File "<pyshell#2>", line 1, in <module> 
10+'5' 
or unsupported operand type(s) for +: ‘int’ and 'str' 
>>> 





Figure 1.4: Example of built-in exceptions 


A programmer can also create custom exceptions to 
suit one’s requirements. These are called user-defined 
exceptions. We will learn how to handle exceptions in 
the next section. 


1.5 Raisinc EXCEPTIONS 


Each time an error is detected in a program, the Python 
interpreter raises (throws) an exception. Exception 
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handlers are designed to execute when a specific 
exception is raised. Programmers can also forcefully 
raise exceptions in a program using the raise and assert 
statements. Once an exception is raised, no further 
statement in the current block of code is executed. So, 
raising an exception involves interrupting the normal 
flow execution of program and jumping to that part of 
the program (exception handler code) which is written 
to handle such exceptional situations. 


1.5.1 The raise Statement 


The raise statement can be used to throw an exception. 
The syntax of raise statement is: 


raise exception-name[ (optional argument) ] 


The argument is generally a string that is displayed 
when the exception is raised. For example, when an 
exception is raised as shown in Figure 1.5, the message 
“OOPS : An Exception has occurred” is displayed along 
with a brief description of the error. 


Lä Pythons 3.7.0 Sheil | CEE 
File Edit Shell Debug Options Window Heip | 
‘Python 3.7.0 (W3.7.0:1bf9cc5093, Jun 27 2018, 04:59:51) [MSC v.1914 64 bit (AMD6 — 
4)] on win32 

Type "copyright", "credits" or "license()" for more information. 

>>> raise Exception ("OOPS!! An Exception has occurred") 


Traceback (most recent call last): 
File "<pyshell#0>", line 1, in <module> 
raise Exception ("OOPS!! An Exception has occurred") 
cea aa OOPS!! An Exception has occurred 
>>> 





Figure 1.5: Use of the raise statement to throw an exception 


The error detected may be a built-in exception or 
may be a user-defined one. Consider the example given 
in Figure 1.6 that uses the raise statement to raise a 
built-in exception called IndexError. 


Note: In this case, the user has only raised the exception but 
has not displayed any error message explicitly. 





In Figure 1.6, since the value of variable length 
is greater than the length of the list numbers, an 
IndexError exception will be raised. The statement 
following the raise statement will not be executed. So 
the message “NO EXECUTION?” will not be displayed in 
this case. 
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Lap Python 3.7.0 Shed 
|| File Edit Shet Debug Opens Window Help 


As we can see in Figure 1.6, in addition to the 
error message displayed, Python also displays a stack 
Traceback. This is a structured block of text that 
contains information about the sequence of function 
calls that have been made in the branch of execution of 
code in which the exception was raised. In Figure 1.6, 
the error has been encountered in the most recently 
called function that has been executed. 


|Python 3.7.0 (v3.7.0:1bf9cc5093, Jun 27 2018, 04:59:51) [MSC v.1914 64 bit (AMD6 -` 


/}4)] on win32 


Type "copyright", "credits" or "license()" for more information. 
|>>> numbers=[40,50,60, 70) 


>>> length=10 


||>>> if length>len (numbers) : 
raise IndexErrocr 
print ("NO EXECUTION") 


else: 


print (length) 


Traceback (most recent call last): 
File "<pyshell#7>", line 2, in <module> 


raise IndexError 
IndexError 
>>> | 





Figure 1.6: Use of raise statement with built-in exception 


Note: We will learn about Stack in Chapter 3. 


1.5.2 The assert Statement 


An assert statement in Python is used to test an 
expression in the program code. If the result after testing 
comes false, then the exception is raised. This statement 
is generally used in the beginning of the function or after 
a function call to check for valid input. The syntax for 
assert statement is: 

assert Expression[,arguments] 


On encountering an assert statement, Python 
evaluates the expression given immediately after 
the assert keyword. If this expression is false, an 
AssertionError exception is raised which can be handled 
like any other exception. Consider the code given in 
Program 1-1. 


Program 1-1 Use of assert statement 


print ("use of assert statement") 
def negativecheck (number): 
assert (number>=0), "OOPS... Negative Number" 
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print (number*number) 
print (negativecheck (100) ) 
print (negativecheck (-350) ) 


| ap Python 3.7.0 Shel 

Fle Ede Sheh Debug Options Windom Help | 
Python 3.7.0 (w3.7.0:1b29ces093, Jun 27 2018, 04:59:51} [MSC v.1914 64 Bit (AMD6 “ 
4))] on win32 

Type “copyright", "credits" or “License()" for more information. 

>>> 

RESTART: C:\Users\admin\Desktop\NCERT\ python programs for exception handling\as 
sert exanple.py 


use of assert statement 


10000 


Hone 
Traceback {most recent call last): 
File "C:\Users\admin\Desktop\NCERT\ python programs for exception handling\asse 
rt example.py", line 6, in <module> 
print (negativecheck (-250)) 
File "C:\Users\admin\Desktop\NCERT\python programs for exception handling\asse 
rt example.py", line 3, in negativecheck 
assert (number>=6), "OOPS... Negative Number" 


ASS@rtionError: OOPS... Negative Number 
>>> 





Figure 1.7: Output of Program 1-1. 


In the code, the assert statement checks for the 
value of the variable number. In case the number gets 
a negative value, AssertionError will be thrown, and 
subsequent statements will not be executed. Hence, 
on passing a negative value (-350) as an argument, it 
results in AssertionError and displays the message 
“OOPS.... Negative Number”. The output of the code is 
shown in Figure 1.7. 


1.6 HANDLING EXCEPTIONS 


Each and every exception has to be handled by the 
programmer to avoid the program from crashing 
abruptly. This is done by writing additional code in 
a program to give proper messages or instructions to 
the user on encountering an exception. This process is 
known as exception handling. 





1.6.1 Need for Exception Handling 


Exception handling is being used not only in Python 
programming but in most programming languages like 
C++, Java, Ruby, etc. It is a useful technique that helps 
in capturing runtime errors and handling them so as to 
avoid the program getting crashed. Following are some 
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of the important points regarding exceptions and their 
handling: 


e Python categorises exceptions into distinct types so 
that specific exception handlers (code to handle that 
particular exception) can be created for each type. 


e Exception handlers separate the main logic of the 
program from the error detection and correction 
code. The segment of code where there is any 
possibility of error or exception, is placed inside one 
block. The code to be executed in case the exception 
has occurred, is placed inside another block. These 
statements for detection and reporting the exception 
do not affect the main logic of the program. 


e The compiler or interpreter keeps track of the exact 
position where the error has occurred. 


e Exception handling can be done for both user-defined 
and built-in exceptions. 


1.6.2 Process of Handling Exception 


When an error occurs, Python interpreter creates an 
object called the exception object. This object contains 
information about the error like its type, file name and 
Ke position in the program where the error has occurred. 
The object is handed over to the runtime system so that 


A runtime system 


a ee ee it can find an appropriate code to handle this particular 
execution of the exception. This process of creating an exception object 
statements given in and handing it over to the runtime system is called 
the program. It is a throwing an exception. It is important to note that 
complex mechanism . ; . 
casino. when an exception occurs while executing a particular 
hardware and program statement, the control jumps to an exception 
software that handler, abandoning execution of the remaining 
comes into action program statements. 
as soon as the 
program, written in The runtime system searches the entire program 
oy Poe A for a block of code, called the exception handler that 


ee lor can handle the raised exception. It first searches for 
l ue the method in which the error has occurred and the 

exception has been raised. If not found, then it searches 

the method from which this method (in which exception 

was raised) was called. This hierarchical search in 

reverse order continues till the exception handler is 

found. This entire list of methods is known as call stack. 

When a suitable handler is found in the call stack, it 

is executed by the runtime process. This process of 
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executing a suitable handler is known as catching the 
exception. If the runtime system is not able to find an 
appropriate exception after searching all the methods in 
the call stack, then the program execution stops. 


The flowchart in Figure 1.8 describes the exception 
handling process. 


An error encountered 
in a method 


4 


Create exception 
object 


4 


Exception is raised i , 
Throwing Exception 


Runtime system 
searches for exception 
handler in the current 

method 


Found 4 VV Found 


Executes the code (a Searches for methods in call 
(Catching an Exception) Found stack in reverse sequence. 


(Forwarding the exception) 


Je: Found 


Program terminates 








Figure 1.8: Steps of handling exception 


1.6.3 Catching Exceptions 


An exception is said to be caught when a code that is 
designed to handle a particular exception is executed. 
Exceptions, if any, are caught in the try block and 
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handled in the except block. While writing or debugging 
a program, a user might doubt an exception to occur 
in a particular part of the code. Such suspicious 
lines of codes are put inside a try block. Every try 
block is followed by an except block. The appropriate 
code to handle each of the possible exceptions (in 
the code inside the try block) are written inside the 
except clause. 


While executing the program, if an exception is 
encountered, further execution of the code inside the 
try block is stopped and the control is transferred to 
the except block. The syntax of try ... except clause 
is as follows: 


Cry: 
[ program statements where exceptions might occur] 

except [exception-name]: 
[ code for exception handling if the exception-name error is 
encountered] 


Consider the Program 1-2 given below: 
Program 1-2 Using try..except block 


print ("Practicing for try DlLocKk?) 

LEV: 
numerator=50 
denom=int (input ("Enter the denominator") ) 
quotient=(numerator/denom) 


print ("Division performed successfully") 
except ZeroDivisionError: 
print ("Denominator as ZERO.... not allowed") 


print (“OUTSIDE try..exe@pt block”) 


In Program 1-2, the ZeroDivisionError exception 
is handled. If the user enters any non-zero value as 
denominator, the quotient will be displayed along with 
the message “Division performed successfully’, as 
shown in Figure 1.10. The except clause will be skipped 
in this case. So, the next statement after the try..except 
block is executed and the message “OUTSIDE try.. 
except block” is displayed. 





However, if the user enters the value of denom as 
zero (0), then the execution of the try block will stop. 
The control will shift to the except block and the 
message “Denominator as Zero... not allowed” will 
be displayed, as shown in Figure 1.11. Thereafter , the 
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statement following the try..except block is executed 
and the message “OUTSIDE try..except block” is 
displayed in this case also. 


Lg Python 3.7.0 Shell 
File Edit Shell Debug Options Window Help 
Python 3.7.0 (vw3.7.0:1bf9cc5093, Jun 27 2018, 04:59:51) [MSc v.1914 64 bit (AMD6 -` 
4)] on win32 
Type "copyright", "credits" or "license()" for more information. 
>>> 
RESTART: C:/Users/admin/Desktop/NCERT/python programs for exception handling/tr 


y except mar 2020 example.py 
Practicing for try block 

Enter the denominatori2 

Division performed successfully 

OUTSIDE try..except block 

>>> | 





Figure 1.9: Output without an error 


| Python 3.7.0 Shell hoc) E ES 
File Eda Shell Debug Options Window Help 
Python 3.7.0 (v3.7.0:1ibf9cc5093, Jun 27 2018, 04:59:51) [M5C v.1914 64 bit (AMD6 5 
4)) on win32 
Type "copyright", "credits" or "lLicense()" for more information. 
>>> 
RESTART: C:/Users/admin/Desktop/NCERT/python programs for exception handling/tr 
y_except mar 2020 example.py 
Practicing for try block 
Enter the denominator0 
Denominator as ZERO.... not allowed 
OUTSIDE try. .except block 
>>> 





Figure 1.10: Output with exception raised 


Sometimes, a single piece of code might be suspected 
to have more than one type of error. For handling such 
situations, we can have multiple except blocks for a 
single try block as shown in the Program 1-3. 


Program 1-3 Use of multiple except clauses 


print ("Handling multiple exceptions") 

CEV: 
numerator=50 
denom=int (input ("Enter the denominator: ")) 
print (numerator/denom) 


print ("Division performed successfully") 
except ZeroDivisionError: 
print ("Denominator as ZERO is not allowed") 


except ValueError: 
print ("Only INTEGERS should be entered") 
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In the code, two types of exceptions (ZeroDivisionError 
and ValueError) are handled using two except blocks 
for a single try block. When an exception is raised, 
a search for the matching except block is made till 
it is handled. If no match is found, then the program 
terminates. 


However, if an exception is raised for which no 
handler is created by the programmer, then such an 
exception can be handled by adding an except clause 
without specifying any exception. This except clause 
should be added as the last clause of the try..except 
block. The Program 1-4 given below along with the 
output given in Figure 1.11 explains this. 


Program 1-4 Use of except without specifying an exception 


print ("Handling exceptions without naming them") 
try: 

numerator=50 

denom=int (input ("Enter the denominator") ) 

quotient=(numerator/denom) 

print ("Division performed successfully") 
except ValueError: 

print ("Only INTEGERS should #e entered") 
except: 

print(” OOPS eesin SOME EXCEPTION RAISED") 

If the above code is executed, and the denominator 
entered is O (zero) , the handler for ZeroDivisionError 
exception will be searched. Since it is not present, the 
last except clause (without any specified exception) 
will be executed , so the message “ OOPS.....SOME 
EXCEPTION RAISED” will be displayed. 


| La Python 3.7.0 Shell 


|| File Edit Shell Debug Options Window Help 
‘Python 3.7.0 (w3.7.0:1bf$ec5093, Jun 27 2018, 04:59:51) [MSC v.1914 64 bit (AMD6 ^ 

1/4) ] on win32 

|| Type "copyright", "credits" or "license()" for more information. 

|| >> 


RESTART: C:/Users/admin/Desktop/NCERT/python programs for exception handling/mu 
itiple exception example mar2z020.py 
Handling exceptions without naming them 
|| Enter the denominator 
SOME EXCEPTION RAISED 





Figure 1.11: Output of Program 1-4 


1.6.4 try. ..except..else clause 


We can put an optional else clause along with the 
try...except clause. An except block will be executed 
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only if some exception is raised in the try block. But if 
there is no error then none of the except blocks will 
be executed. In this case, the statements inside the 
else clause will be executed. Program 1-5 along with 
its output explains the use of else block with the try... 
except block. 


Program 1-5 Use of else clause 


print ("Handling exception using try...except...else") 
BEY 
numerator=50 
denom=int (input ("Enter the denominator: ")) 
quotient=(numerator/denom) 
print ("Division performed successfully") 


except ZeroDivisionError: 
print ("Denominator as ZERO is not allowed") 


except ValueError: 
print ("Only INTEGERS should be entered") 


else: 
print ("The result of division operation is ", quotient) 


Output: 


| à Python 3.7.0 Sheli 
|| Fie Eda Shel Debug Optics Window Help 
i Python 3.7.0 (v3.7.0:1bf9cc5093, Jun 27 2018, 04:59:51) [MSC v.1914 64 bit (AMD6 - 

4)] on wins? 

Type "copyright", "credits" or "license()" for more information. 

>>> 

RESTART: C:/Users/admin/Desktop/NCERT/latest programs and images for exception 


handling/prog 1.2.py 
Handling exception using try...except...else 
Enter the denominatorS 
Division performed successfully 
The result of division operation is 10.0 
>>> | 





Figure 1.12: Output of Program 1-5. 
1.7 FINALLY CLAUSE 


The try statement in Python can also have an optional 
finally clause. The statements inside the finally block 
are always executed regardless of whether an exception 
has occurred in the try block or not. It is a common 
practice to use finally clause while working with files 
to ensure that the file object is closed. If used, finally 
should always be placed at the end of try clause, after 
all except blocks and the else block. 
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Program 1-6 Use of finally clause 


print ("Handling exception using try...except...else...finally") 
Ley: 
numerator=50 
denom=int (input ("Enter the denominator: ")) 
quotient=(numerator/denom) 


print ("Division performed successfully") 
except ZeroDivisionkError: 
print ("Denominator as ZERO is not allowed") 


except ValueError: 

print ("Only INTEGERS should be entered") 
else: 

print ("The result of division operation is ", quotient) 
finally: 

print ("OVER AND OUT") 


In the above program, the message “OVER AND OUT” 
will be displayed irrespective of whether an exception is 
raised or not. 


1.6.1 Recovering and continuing with finally clause 


If an error has been detected in the try block and the 
exception has been thrown, the appropriate except 
block will be executed to handle the error. But if the 
exception is not handled by any of the except clauses, 
then it is re-raised after the execution of the finally 
block. For example, Program 1.4 contains only the 
except block for ZeroDivisionError. If any other 
type of error occurs for which there is no handler code 
(except clause) defined, then also the finally clause will 
be executed first. Consider the code given in Program 
1-7 to understand these concepts. 


Program 1-7 Recovering through finally clause 


prine (" Practicing for try block”) 

Ciy: 
numerator=50 
denom=int (input ("Enter the denominator") ) 
quotient=(numerator/denom) 





print ("Division performed successfully") 
except ZeroDivisionError: 

print ("Denominator as ZERO is not allowed") 
else: 

print ("The result of division operation is ", quotient) 
finally: 


Print ("OVER AND OUT™) 
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While executing the above code, if we enter a 
non-numeric data as input, the finally block will be 
executed. So, the message “OVER AND OUT” will be 
displayed. Thereafter the exception for which handler is 
not present will be re-raised. The output of Program 1-7 
is shown in Figure 1.13. 


| ah Python 3.7.0 Sheli 
|| Fae Edi Shel Debug Opia Window Help 
|| Python 3.7.0 (v3.7.0:1bf9cc5093, Jun 27 2018, 04:59:51) [MSC v.1914 64 bit (AMD6 -` 
4)] on win32 
Type "copyright", "credits" or "license()" for more information. 
oe 
RESTART: C:/Users/admin/Desktop/NCERT/latest programs and images for exception 
handling/try finally example fig 1.12.py 
Practicing for try block 
| Enter the denominatorvar 
OVER AND OUT 
Traceback (most recent call last): 
File "C:/Users/admin/Desktop/NCERT/latest programs and images for exception ha 
ndling/try finally example fig 1.12.py", line 4, in <module> 
denom=int (input ("Enter the denominator") ) 
ValueError: invalid literal for int() with base 10: 'var' 
>>> | 





Figure 1.13: Output of Program 1-7 


After execution of finally block, Python transfers 
the control to a previously entered try or to the next 
higher level default exception handler. In such a case, 
the statements following the finally block is executed. 
That is, unlike except, execution of the finally clause 
does not terminate the exception. Rather, the exception 
continues to be raised after execution of finally. 


To summarise, we put a piece of code where there 
are possibilities of errors or exceptions to occur inside 
a try block. Inside each except clause we define handler 
codes to handle the matching exception raised in the 
try block. The optional else clause contains codes to 
be executed if no exception occurs. The optional finally 
block contains codes to be executed irrespective of 
whether an exception occurs or not. 
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SUMMARY 


e Syntax errors or parsing errors are detected when 
we have not followed the rules of the particular 
programming language while writing a program. 


MANNII LLL LLL LLL 


A 
f 
f 
Z 
Z 
j 
Z 
j 
Z 
j 
Z 
f 
J 


DOMSSAiQ QBN 





EXCEPTION HANDLING IN PYTHON 





2020-21 


NOH, w+ DDN TAA. 

e When syntax error is encountered, Python displays 
the name of the error and a small description 
about the error. 


NOTES 


e The execution of the program will start only after 
the syntax error is rectified. 


e An exception is a Python object that represents 
an error. 


e Syntax errors are also handled as exceptions. 


e The exception needs to be handled by the 
programmer so that the program does not 
terminate abruptly. 


e When an exception occurs during execution 
of a program and there is a built-in exception 
defined for that, the error message written in that 
exception is displayed. The programmer then has 
to take appropriate action and handle it. 


e Some of the commonly occurring built-in 
exceptions are SyntaxError, Valu Error, 
TOETO TPO r N viet tao by TIO Err or, 
EOFError, ACroDINSIonError, IndexError; 
NameErrom Mdau at ionError, TypeError,and 
OverFloperroñ 


e When an error is encountered in a program, 
Python interpreter raises or throws an exception. 


e Exception Handlers are the codes that are 
designed to execute when a specific exception 
is raised. 


e Raising an exception involves interrupting the 
normal flow of the program execution and jumping 
to the exception handler. 


e Raise and assert statements are used to raise 
exceptions. 


e The process of exception handling involves 
writing additional code to give proper messages 
or instructions to the user. This prevents the 
program from crashing abruptly. The additional 
code is Known as an exception handler. 





e An exception is said to be caught when a code 
that is designed to handle a particular exception 
is executed. 


e An exception is caught in the try block and 
handles in except block. 
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e The statements inside the finally block are always 
executed regardless of whether an exception 


occurred in the try block or not. 
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1. “Every syntax error is an exception but every exception 
cannot be a syntax error.” Justify the statement. 


JANN 
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2. When are the following built-in exceptions raised? Give 
examples to support your answers. 
a) ImportError 
b) IOError 
c) NameError 
d) ZeroDivisionError 


3. What is the use of a raise statement? Write a code to 
accept two numbers and display the quotient. Appropriate 
exception should be raised if the user enters the second 
number (denominator) as zero (0). 


4. Use assert statement in Question No. 3 to test the 
division expression in the program. 


5. Define the following: 
a) Exception Handling 
b) Throwing an exception 
c) Catching an exception 


6. Explain catching exceptions using try and except block. 


7. Consider the code given below and fill in the blanks. 
print (" Learning Exceptions...") 


ate 
numl= int (input\(" Enter the first number") 
num2=int (input ("Enter the second number") ) 


quotient=(numl/num2) 





print ("Both the numbers entered were correct") 
except _  —  — _ _ l # to enter only integers 
print (" Please enter only numbers") 
except —  — _ — _ _ _ # Denominator should not be zero 
Printi” Number 2 should not be zero") 
else: 
print (" Great .. you are a good programmer") 


# to be executed at the end 
prance (™ JOB OVER... GO GET SOME REST") 
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NOTES 


You have learnt how to use math module in Class 
XI. Write a code where you use the wrong number of 
arguments for a method (say sqrt() or pow()). Use the 
exception handling process to catch the ValueError 
exception. 


What is the use of finally clause? Use finally clause in 
the problem given in Question No. 7. 
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